草庐IT

Java 线程终止引用

全部标签

ruby - GMail 线程、IMAP 和 Ruby

我正在使用RubyIMAP库来获取GMail对话。GMail线程对话的方式是通过“Message-ID”和“In-Reply-To”邮件header。例如:In-Reply-To:Message-ID:我不知道如何有效地获取回复消息。当前方式:target=imap.search(["NOT","DELETED"]).eachdo|msg_id|uid=imap.fetch(message_id,"ENVELOPE")[0].attr["ENVELOPE"].message_idifuid==targetm=imap.fetch(msg_id,"RFC822")[0].attr["RF

ruby-on-rails - Ruby 为什么类实例变量是线程安全的

根据this回答是,但是张贴者说JRuby的工作方式不同所以我很困惑?我正在使用类实例变量实现Multi-Tenancy解决方案,因此无论我使用什么Ruby实现或Web服务器,我都需要确保数据不会泄露。这是我的代码:classTenant我需要做什么来确保无论发生什么(更改Ruby实现、更改Web服务器、新的Ruby线程功能等)我的代码都是线程安全的? 最佳答案 由于tenancy属性的范围是一个请求,我建议您将其保留在当前线程的范围内。由于一个请求是在单个线程上处理的,并且一个线程一次处理一个请求-只要您始终在请求开始时设置租期就

ruby - 如何在 ruby​​ 中控制(启动/终止)后台进程(服务器应用程序)

我正在尝试通过ruby​​为集成测试(实际上是规范)设置一个服务器,但不知道如何控制该过程。所以,我要做的是:为我的gem运行一个执行集成规范的rake任务任务需要先启动服务器(我使用webrick),然后运行规范执行规范后,它应该会杀死webrick,这样我就不会留下一些未使用的后台进程webrick不是必需的,但它包含在ruby​​标准库中,因此能够使用它会很棒。希望有人能提供帮助!附言。我在linux上运行,所以让这个适用于windows的工作不是我的主要优先事项(现在)。 最佳答案 标准方法是使用系统函数fork(复制当前进

ruby - ruby 中的线程安全外部进程,以及检查退出状态

我想在Ruby中运行一段调用外部程序的线程安全脚本,然后检查该外部程序的退出状态。最好的方法是什么?到目前为止,我一直在检查$?,但我认为我遇到了与程序其他部分的竞争条件。下面是一些示例代码:Thread.newdo`external_program`if$?.exitstatus==0#itworked.else#itdidn'twork.endend理想情况下,我会做类似的事情Process.new(`external_program`).exitstatus因此exitstatus与that进程密不可分,而不是恰好完成的最后一个进程。有什么办法吗? 最

ruby-on-rails - 如何改进用 `' ` 引用所有数组元素并返回包含所有这些引用和逗号分隔元素的字符串的代码?

我正在使用Rails3.2.2,我想用'引用所有数组元素并返回一个包含所有这些引用和逗号分隔元素的字符串。这时候我在用['a','b','c'].collect{|x|"'#{x}'"}.join(",")#=>"'a','b','c'"但我认为我可以改进上面的代码(也许通过使用一个我不知道的Ruby方法,如果它存在的话)。可能吗? 最佳答案 我用"'#{%w{abc}.join("','")}'"这里是扩展版:'#Startingquote%w{abc}.join("','")#Joinarraywith','delimitert

ruby-on-rails - 自引用问题 has_many :through associations in Rails

我今天正在阅读有关自引用has_many:through数据情况的文章,因为我正在尝试构建一个使用它们的Rails应用程序。我找到了这个examplesituation在互联网上,我对此有疑问。让我从这个人的博客中发布这个示例代码:create_table:animalsdo|t|t.string:speciesendcreate_table:huntsdo|t|t.integer:predator_idt.integer:prey_idt.integer:capture_percentendclassAnimal'predator_id',:class_name=>'Hunt',:d

ruby-on-rails - RubyMine 中未解析的 ruby​​ 引用

有什么方法可以避免在RubyMineIDE中出现“未解析的ruby​​引用”警告?例如,当我的View中的某些代码调用View助手的方法时,即使代码有效,我也会收到“未解析的ruby​​引用”警告。上述案例只是众多案例中的一个。另一个例子是使用RSpec时:it"shouldrequireanemail"dono_email_user=User.new(@attr.merge(:email=>""))no_email_user.should_notbe_validendRubyMineIDE不知道参数“be_valid”。我的问题是-有什么办法可以解决这个问题吗?我应该需要额外的文件吗

ruby-on-rails - Phusion Passenger 如何重用线程和进程?

我正在设置一个Apache2网络服务器,使用PhusionPassenger运行多个RubyonRails网络应用程序。我知道Passenger生成Ruby进程来处理请求。我有以下问题:如果必须同时处理多个请求,Passenger会生成多个进程还是多个(Ruby)线程?如何配置它以使其始终生成单线程进程?如果我有两个Rails应用程序,假设对应用程序A的请求进入进程1,然后对应用程序B的请求到达。进程1是否也可能处理此请求?什么时候以及如何做到这一点?换句话说,是否允许一个进程处理多个Rails应用程序的请求?我在多个URL和多个虚拟主机(例如http://和https://)中导出了

ruby - 将电子邮件组织成线程的算法?

是否有任何命名/著名/特别好的算法来将电子邮件消息组织到线程中?我想在我的网站上添加一个类似于Google网上论坛(和其他邮寄列表)的功能,我只是想知道是否有任何已发布的此类组织算法。我知道推出我自己的算法可能相当容易,但可通过的算法和良好的算法之间的用户体验可能存在很大差异。已在ruby​​中实现的算法的奖励积分! 最佳答案 jwz_threading看起来正是您要的。我没用过。 关于ruby-将电子邮件组织成线程的算法?,我们在StackOverflow上找到一个类似的问题:

ruby - 在 Ruby 版本管理器 (RVM) 中清理旧引用

我需要释放本地计算机上的磁盘空间,该空间几乎已分配到我的Ruby版本管理器(RVM)目录中。现在,我似乎只有一个ruby​​版本(1.9.2p136):lsoave@ubuntu:~/rails/github/gitwatcher$ruby-vruby1.9.2p136(2010-12-25revision30365)[i686-linux]lsoave@ubuntu:~/rails/github/gitwatcher$lsoave@ubuntu:~/rails/github/gitwatcher$rvmlistrvmrubies=>ruby-1.9.2-p136[i386]lsoav